package com.cencat.order.domain;

import com.baomidou.mybatisplus.annotation.*;
import com.fasterxml.jackson.annotation.JsonFormat;
import jakarta.validation.constraints.*;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;

import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * 智能派单信息实体类
 * 
 * @author cencat
 * @date 2024-01-20
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("sys_dispatch")
public class Dispatch implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 派单ID
     */
    @TableId(value = "dispatch_id", type = IdType.AUTO)
    private Long dispatchId;

    /**
     * 派单编号
     */
    @NotBlank(message = "派单编号不能为空")
    @Size(max = 50, message = "派单编号长度不能超过50个字符")
    @TableField("dispatch_code")
    private String dispatchCode;

    /**
     * 订单ID
     */
    @NotNull(message = "订单ID不能为空")
    @TableField("order_id")
    private Long orderId;

    /**
     * 订单编号
     */
    @NotBlank(message = "订单编号不能为空")
    @Size(max = 50, message = "订单编号长度不能超过50个字符")
    @TableField("order_code")
    private String orderCode;

    /**
     * 路线ID
     */
    @TableField("route_id")
    private Long routeId;

    /**
     * 路线编号
     */
    @Size(max = 50, message = "路线编号长度不能超过50个字符")
    @TableField("route_code")
    private String routeCode;

    /**
     * 路线名称
     */
    @Size(max = 100, message = "路线名称长度不能超过100个字符")
    @TableField("route_name")
    private String routeName;

    /**
     * 司机ID
     */
    @TableField("driver_id")
    private Long driverId;

    /**
     * 司机编号
     */
    @Size(max = 50, message = "司机编号长度不能超过50个字符")
    @TableField("driver_code")
    private String driverCode;

    /**
     * 司机姓名
     */
    @Size(max = 50, message = "司机姓名长度不能超过50个字符")
    @TableField("driver_name")
    private String driverName;

    /**
     * 司机手机号
     */
    @Pattern(regexp = "^1[3-9]\\d{9}$", message = "手机号格式不正确")
    @TableField("driver_phone")
    private String driverPhone;

    /**
     * 车辆ID
     */
    @TableField("vehicle_id")
    private Long vehicleId;

    /**
     * 车牌号
     */
    @Size(max = 20, message = "车牌号长度不能超过20个字符")
    @TableField("vehicle_plate")
    private String vehiclePlate;

    /**
     * 车辆类型
     */
    @Size(max = 50, message = "车辆类型长度不能超过50个字符")
    @TableField("vehicle_type")
    private String vehicleType;

    /**
     * 商家ID
     */
    @TableField("merchant_id")
    private Long merchantId;

    /**
     * 商家名称
     */
    @Size(max = 100, message = "商家名称长度不能超过100个字符")
    @TableField("merchant_name")
    private String merchantName;

    /**
     * 派单类型(1-智能派单 2-手动派单 3-紧急派单 4-批量派单)
     */
    @NotNull(message = "派单类型不能为空")
    @TableField("dispatch_type")
    private Integer dispatchType;

    /**
     * 派单方式(1-系统自动 2-人工指派 3-司机抢单)
     */
    @NotNull(message = "派单方式不能为空")
    @TableField("dispatch_method")
    private Integer dispatchMethod;

    /**
     * 派单状态(0-待派单 1-已派单 2-已接单 3-已拒绝 4-已取消 5-已完成 6-异常)
     */
    @NotNull(message = "派单状态不能为空")
    @TableField("dispatch_status")
    private Integer dispatchStatus;

    /**
     * 优先级(1-低 2-中 3-高 4-紧急)
     */
    @Min(value = 1, message = "优先级不能小于1")
    @Max(value = 4, message = "优先级不能大于4")
    @TableField("priority")
    private Integer priority;

    /**
     * 紧急程度(1-普通 2-加急 3-特急)
     */
    @Min(value = 1, message = "紧急程度不能小于1")
    @Max(value = 3, message = "紧急程度不能大于3")
    @TableField("urgency_level")
    private Integer urgencyLevel;

    /**
     * 货物重量(公斤)
     */
    @DecimalMin(value = "0.0", message = "货物重量不能小于0")
    @TableField("cargo_weight")
    private BigDecimal cargoWeight;

    /**
     * 货物体积(立方米)
     */
    @DecimalMin(value = "0.0", message = "货物体积不能小于0")
    @TableField("cargo_volume")
    private BigDecimal cargoVolume;

    /**
     * 货物类型
     */
    @Size(max = 100, message = "货物类型长度不能超过100个字符")
    @TableField("cargo_type")
    private String cargoType;

    /**
     * 货物描述
     */
    @Size(max = 500, message = "货物描述长度不能超过500个字符")
    @TableField("cargo_desc")
    private String cargoDesc;

    /**
     * 特殊要求
     */
    @Size(max = 500, message = "特殊要求长度不能超过500个字符")
    @TableField("special_requirements")
    private String specialRequirements;

    /**
     * 取货地址
     */
    @NotBlank(message = "取货地址不能为空")
    @Size(max = 200, message = "取货地址长度不能超过200个字符")
    @TableField("pickup_address")
    private String pickupAddress;

    /**
     * 取货联系人
     */
    @NotBlank(message = "取货联系人不能为空")
    @Size(max = 50, message = "取货联系人长度不能超过50个字符")
    @TableField("pickup_contact")
    private String pickupContact;

    /**
     * 取货联系电话
     */
    @NotBlank(message = "取货联系电话不能为空")
    @Pattern(regexp = "^1[3-9]\\d{9}$", message = "取货联系电话格式不正确")
    @TableField("pickup_phone")
    private String pickupPhone;

    /**
     * 取货纬度
     */
    @DecimalMin(value = "-90.0", message = "纬度范围不正确")
    @DecimalMax(value = "90.0", message = "纬度范围不正确")
    @TableField("pickup_latitude")
    private BigDecimal pickupLatitude;

    /**
     * 取货经度
     */
    @DecimalMin(value = "-180.0", message = "经度范围不正确")
    @DecimalMax(value = "180.0", message = "经度范围不正确")
    @TableField("pickup_longitude")
    private BigDecimal pickupLongitude;

    /**
     * 配送地址
     */
    @NotBlank(message = "配送地址不能为空")
    @Size(max = 200, message = "配送地址长度不能超过200个字符")
    @TableField("delivery_address")
    private String deliveryAddress;

    /**
     * 配送联系人
     */
    @NotBlank(message = "配送联系人不能为空")
    @Size(max = 50, message = "配送联系人长度不能超过50个字符")
    @TableField("delivery_contact")
    private String deliveryContact;

    /**
     * 配送联系电话
     */
    @NotBlank(message = "配送联系电话不能为空")
    @Pattern(regexp = "^1[3-9]\\d{9}$", message = "配送联系电话格式不正确")
    @TableField("delivery_phone")
    private String deliveryPhone;

    /**
     * 配送纬度
     */
    @DecimalMin(value = "-90.0", message = "纬度范围不正确")
    @DecimalMax(value = "90.0", message = "纬度范围不正确")
    @TableField("delivery_latitude")
    private BigDecimal deliveryLatitude;

    /**
     * 配送经度
     */
    @DecimalMin(value = "-180.0", message = "经度范围不正确")
    @DecimalMax(value = "180.0", message = "经度范围不正确")
    @TableField("delivery_longitude")
    private BigDecimal deliveryLongitude;

    /**
     * 预计距离(公里)
     */
    @DecimalMin(value = "0.0", message = "预计距离不能小于0")
    @TableField("estimated_distance")
    private BigDecimal estimatedDistance;

    /**
     * 预计时长(分钟)
     */
    @Min(value = 0, message = "预计时长不能小于0")
    @TableField("estimated_duration")
    private Integer estimatedDuration;

    /**
     * 预计费用
     */
    @DecimalMin(value = "0.0", message = "预计费用不能小于0")
    @TableField("estimated_fee")
    private BigDecimal estimatedFee;

    /**
     * 实际费用
     */
    @DecimalMin(value = "0.0", message = "实际费用不能小于0")
    @TableField("actual_fee")
    private BigDecimal actualFee;

    /**
     * 派单时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("dispatch_time")
    private LocalDateTime dispatchTime;

    /**
     * 接单时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("accept_time")
    private LocalDateTime acceptTime;

    /**
     * 拒绝时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("reject_time")
    private LocalDateTime rejectTime;

    /**
     * 拒绝原因
     */
    @Size(max = 200, message = "拒绝原因长度不能超过200个字符")
    @TableField("reject_reason")
    private String rejectReason;

    /**
     * 取消时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("cancel_time")
    private LocalDateTime cancelTime;

    /**
     * 取消原因
     */
    @Size(max = 200, message = "取消原因长度不能超过200个字符")
    @TableField("cancel_reason")
    private String cancelReason;

    /**
     * 完成时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("complete_time")
    private LocalDateTime completeTime;

    /**
     * 要求取货时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("required_pickup_time")
    private LocalDateTime requiredPickupTime;

    /**
     * 要求送达时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("required_delivery_time")
    private LocalDateTime requiredDeliveryTime;

    /**
     * 实际取货时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("actual_pickup_time")
    private LocalDateTime actualPickupTime;

    /**
     * 实际送达时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("actual_delivery_time")
    private LocalDateTime actualDeliveryTime;

    /**
     * 算法版本
     */
    @Size(max = 20, message = "算法版本长度不能超过20个字符")
    @TableField("algorithm_version")
    private String algorithmVersion;

    /**
     * 匹配得分
     */
    @DecimalMin(value = "0.0", message = "匹配得分不能小于0")
    @DecimalMax(value = "100.0", message = "匹配得分不能大于100")
    @TableField("match_score")
    private BigDecimal matchScore;

    /**
     * 匹配因子(JSON格式)
     */
    @TableField("match_factors")
    private String matchFactors;

    /**
     * 派单规则ID
     */
    @TableField("dispatch_rule_id")
    private Long dispatchRuleId;

    /**
     * 派单规则名称
     */
    @Size(max = 100, message = "派单规则名称长度不能超过100个字符")
    @TableField("dispatch_rule_name")
    private String dispatchRuleName;

    /**
     * 重试次数
     */
    @Min(value = 0, message = "重试次数不能小于0")
    @TableField("retry_count")
    private Integer retryCount;

    /**
     * 最大重试次数
     */
    @Min(value = 0, message = "最大重试次数不能小于0")
    @TableField("max_retry_count")
    private Integer maxRetryCount;

    /**
     * 超时时间(分钟)
     */
    @Min(value = 0, message = "超时时间不能小于0")
    @TableField("timeout_minutes")
    private Integer timeoutMinutes;

    /**
     * 是否超时(0-否 1-是)
     */
    @TableField("is_timeout")
    private Integer isTimeout;

    /**
     * 异常信息
     */
    @Size(max = 500, message = "异常信息长度不能超过500个字符")
    @TableField("exception_info")
    private String exceptionInfo;

    /**
     * 处理人ID
     */
    @TableField("handler_id")
    private Long handlerId;

    /**
     * 处理人姓名
     */
    @Size(max = 50, message = "处理人姓名长度不能超过50个字符")
    @TableField("handler_name")
    private String handlerName;

    /**
     * 处理时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("handle_time")
    private LocalDateTime handleTime;

    /**
     * 处理备注
     */
    @Size(max = 500, message = "处理备注长度不能超过500个字符")
    @TableField("handle_remark")
    private String handleRemark;

    /**
     * 评价分数
     */
    @DecimalMin(value = "0.0", message = "评价分数不能小于0")
    @DecimalMax(value = "5.0", message = "评价分数不能大于5")
    @TableField("rating_score")
    private BigDecimal ratingScore;

    /**
     * 评价内容
     */
    @Size(max = 500, message = "评价内容长度不能超过500个字符")
    @TableField("rating_content")
    private String ratingContent;

    /**
     * 评价时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("rating_time")
    private LocalDateTime ratingTime;

    /**
     * 删除标志(0-存在 1-删除)
     */
    @TableLogic
    @TableField("del_flag")
    private Integer delFlag;

    /**
     * 备注
     */
    @Size(max = 500, message = "备注长度不能超过500个字符")
    @TableField("remark")
    private String remark;

    /**
     * 创建者
     */
    @TableField(value = "create_by", fill = FieldFill.INSERT)
    private String createBy;

    /**
     * 创建时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(value = "create_time", fill = FieldFill.INSERT)
    private LocalDateTime createTime;

    /**
     * 更新者
     */
    @TableField(value = "update_by", fill = FieldFill.INSERT_UPDATE)
    private String updateBy;

    /**
     * 更新时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;

    /**
     * 扩展字段1
     */
    @Size(max = 200, message = "扩展字段1长度不能超过200个字符")
    @TableField("ext_field1")
    private String extField1;

    /**
     * 扩展字段2
     */
    @Size(max = 200, message = "扩展字段2长度不能超过200个字符")
    @TableField("ext_field2")
    private String extField2;

    /**
     * 扩展字段3
     */
    @Size(max = 200, message = "扩展字段3长度不能超过200个字符")
    @TableField("ext_field3")
    private String extField3;

    /**
     * 版本号(乐观锁)
     */
    @Version
    @TableField("version")
    private Integer version;
}